전체 QNA

React 에서의 단락 회로 평가에 대해 궁금한 점이 있습니다.

10/12/2023 작성

질문

단락 회로 평가에서 isVisible이 true이면 반드시 뒤에 컴포넌트가 렌더가 되는데 왜 그럼 컴포넌트는 항상 true인가요?

근데 원래가 && 연산자는 앞 뒤 모두 true여야 true인데 이지비지블이 true면 왜 뒤에 컴포넌트는 항상 true인지 궁금합니다?

 

답변

질문 주신 내용은 자바스크립트의 truthy & falsy로 인해 발생하는 현상입니다.

간단하게만 요약하자면 자바스크립트는 true, false같은 불리언 자료형의 값이 아니더라도

조건식에 값이 사용되면 참이나 거짓으로 판단하는 특징을 갖고 있습니다.

여기에 단락 회로 평가가 적용되면 특이한 현상이 한개 더 발생하는데요

다음과 같은 식의 결과는 true가 아니라 truthy한 값으로 평가됩니다.

true && truthy한 값 (예를 들면 10)

그러므로 isVisible && <컴포넌트/> 요런 식은 isVisible이 true일 경우 컴포넌트는 truthy한 값이기 때문에 컴포넌트가 그대로 반환되는 것 입니다.